MySQL数据库连接问题诊断分析

432次阅读
没有评论

共计 2566 个字符,预计需要花费 7 分钟才能阅读完成。

MySQL 服务端使用插件的方式认证客户端的用户身份。认证插件和用户相关,不同用户可以使用不同的插件进行密码验证。创建用户时,如果不显式指定,会使用参数 default_authentication_plugin 指定的插件。从 MySQL 8.0 开始,使用 caching_sha2_password 作为默认的认证插件,而 5.7 使用的默认插件是 mysql_native_password。

MySQL 支持使用 TLS 协议建立加密连接,默认开启。使用 MySQL 客户端登录服务器后,执行 \s,查看 SSL 这一行输出,如果显示“Cipher in use …”,则说明当前连接启用了加密。

可以在连接数据库时指定参数,不开启连接加密,此时“SSL”这一行显示“Not in use”。

mysql --ssl-mode=disabled -uroot -p

当数据库连接不上时,分析问题的一般思路如下。

检查数据库监听是否正常开启

在数据库服务器上通过 netstat 或 ss 命令查看数据库端口监听是否正常开启。

ss -nltp | grep 3306
netstat -nltp | grep 3306

检查客户端到服务端之间网络是否连通

可以使用 telnet 等工具检查客户端到服务端口是否连通。

telnet 172.16.121.234 3306

如果端口不通,使用 MySQL 客户端访问数据库时,会有相应的报错信息。注意报错信息最后括号里的数字(操作系统返回错误码,不用操作系统不一样),可使用 MySQL 提供的工具 perror 查看跟错误码关联的错误信息。

perror 111
perror 113

是否认证阶段出问题

常见报错信息:

  • ERROR 2059,Authentication plugin‘caching_sha2_password’cannot be loaded
    • 客户端版本太低,不支持 caching_sha2_password 认证插件
    • 解决方法:使用新版本客户端
  • ERROR 2061,Authentication requires secure connection
    • 使用 caching_sha2_password 认证插件时,用户首次登录时还没有被缓存,服务端需要获取用户的明文密码,如果客户端没有开启连接加密,发送明文密码有安全风险,就会报这个错误
    • 解决方法:开启连接加密,或者在客户端指定 get-server-public-key 选项
    • 不同客户端指定参数的方式可能会有差异,比如使用 JDBC 时需要添加连接属性 allowPublicKeyRetrieval=true
    • MySQL 备库连接主库时,也可能遇到一样的问题,可以在建立复制时,指定 GET_MASTER_PUBLIC_KEY 或 GET_SOURCE_PUBLIC_KEY 选项
    • 使用 MySQL 组复制(MGR)如果遇到这个问题,可以通过设置参数 group_replication_recovery_get_public_key 来解决
  • ERROR 1045: Access denied for user‘username’@‘hostname’
    • 客户端输入密码不正确引起
    • 如果强制要求用户使用加密连接,或者对客户端证书有要求,而客户端没有满足这些条件,那么连接时也会报这个错

数据库连接数限制

参数 max_connections 限制数据库允许创建的总连接数。参数 max_user_connections 限制同一个用户允许创建的最大连接数。如果连接数超过限制,会报下面这 3 个错误:

  • ERROR 1040 (08004): Too many connections
  • ERROR 1203 (42000): User test already has more than‘max_user_connections’active connections
  • ERROR 1226 (42000): User‘test’has exceeded the‘max_user_connections’resource (current value: 2)

操作系统资源限制

如果操作系统资源超出限制,会导致客户端连接失败,MySQL 服务端无法创建新的线程:ERROR 1135: Can’t create a new thread (errno 11)

如果文件句柄数超出限制,在数据库错误日志中还可能会出现这样的报错信息:[ERROR] [MY-010283] [Server] Error in accept: Too many open files

其它错误

ERROR 1129 (HY000): Host ‘172.16.121.237’ is blocked because of many connection errors; unblock with ‘mysqladmin flush-hosts’。

  • 客户端从某台机器连接数据库时,连续出错,出错次数超过参数 max_connect_errors 设置后,服务端会禁止这台机器后续连接,这里限制的是客户端 IP。从 performance_schema.host_cache 表里,可看到客户端连接错误次数
  • 解决方法:执行 flush hosts 操作
  • 不是所有连接错误都会引起客户端被禁,比如密码错误并不会导致客户端被禁。host_cache 表 COUNT_HANDSHAKE_ERRORS 达到 max_connect_errors,才会导致客户端被禁。比如连续 telnet mysql 端口会引起这个问题,或者使用了无效 ssl 证书可能会导致这个问题

连接中断问题

情况 1:连接被 Kill

如果有人使用 Kill 命令终止某个会话,那么原先客户端在执行 SQL 时,就会发现连接已经中断。

情况 2:数据库重启

如果数据库发生重启,那么原先所有连接都会断开。可通过查看数据库 Uptime 状态变量来判断数据库最近是否有重启。Uptime 记录了数据库从启动后至今经过的秒数。

show global status where variable_name in ('Uptime');

情况 3:连接空闲时间超时

MySQL 中全局变量 interactive_timeout(交互式连接)和 wait_timeout(非交互式连接)用来控制连接空闲超时,如果一个连接在指定时间内没有发起任何请求,就会被服务器断开。

情况 4:代理(Proxy)超时

如果在数据库之前配置了代理,而代理空闲超时时间比较短。应用程序通过代理访问数据库时,就可能会遇到连接中断问题。

正文完
 0
阿伯手记
版权声明:本站原创文章,由 阿伯手记 于2024-11-24发表,共计2566字。
转载说明:本站原创内容,除特殊说明外,均基于 CC BY-NC-SA 4.0 协议发布,转载须注明出处与链接。
评论(没有评论)
验证码

阿伯手记

阿伯手记
阿伯手记
喜欢编程,头发渐稀;成长路上,宝藏满地
文章数
766
评论数
204
阅读量
449996
今日一言
-「
热门文章
职场救急!AI请假话术生成器:1秒定制高通过率理由

职场救急!AI请假话术生成器:1秒定制高通过率理由

超级借口 不好开口?借口交给我!智能生成工作请假、上学请假、饭局爽约、约会拒绝、邀约推辞、万能借口等各种借口理...
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
巴别英语:用美剧和TED演讲轻松提升英语听力与口语

巴别英语:用美剧和TED演讲轻松提升英语听力与口语

还在为枯燥的英语学习而烦恼吗?巴别英语通过创新的美剧学习模式,让英语学习变得生动有趣。平台提供海量美剧和 TE...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
TVAPP:开源电视盒子资源库,一键打造家庭影院

TVAPP:开源电视盒子资源库,一键打造家庭影院

导语 TVAPP 是一个专为 Android TV 电视盒子用户打造的开源影音资源库,集成了影视、直播、游戏等...
2025年12月 每日精选

2025年12月 每日精选

关于每日精选栏目 发现一些不错的资源,点击 这里 快速投稿。 12 月 26 日 .ax 顶级域 目前全球唯一...
最新评论
15220202929 15220202929 怎么用
八对 八对 麻烦大佬更新下【堆新】的友链站名:八对星星描述:极目星视穹苍无界•足履行者大地有疆链接:https://8dui.com图标:https://cf.8dui.com/logo.webp横标:https://cf.8dui.com/logo-w.webp订阅:https://8dui.com/rss.xml
三毛笔记 三毛笔记 已添加
DUINEW DUINEW 已添加贵站,期待贵站友链~博客名称:堆新博客地址:https://duinew.com/博客描述:堆新堆新,引力向新!——堆新(DUINEW)博客头像:https://d.duinew.com/logo.webp横版头像:https://d.duinew.com/logo-w.webp博客订阅:https://duinew.com/rss.xml
hedp hedp 没看懂
bingo bingo 直接生成就可以啦,也可以添加一些选项
满心 满心 申请更新下友联信息,原名:满心记,现名:周天记原域名:qq.mba,现域名:zhoutian.com描述:我在人间混日子
开业吉日 开业吉日 没看明白这个怎么用
开业吉日 开业吉日 beddystories 这个网站太赞了,收藏
热评文章
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
清华大学官方免费DeepSeek教程

清华大学官方免费DeepSeek教程

AI 领域近期最引人注目的焦点当属 DeepSeek,这款由中国创新企业深度求索研发的人工智能工具,正以开放源...
Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 是一款基于 Fastify、Vercel 和 Supabase 构建的 URL 缩短服务...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 是一个致力于为儿童提供优质睡前故事的在线平台,用户可以在这里找到来自世界各地的经典故...
DrawLink:一键生成链接视觉卡片,提升分享点击率

DrawLink:一键生成链接视觉卡片,提升分享点击率

小贴士 :此站或已变迁,但探索不止步。我们已为您备好「类似网站」精选合集,相信其中的发现同样能为您带来惊喜。